import process from 'node:process'
import type { ModuleOptions } from '@vite-pwa/nuxt'
import { appDescription, appName, baseURL } from '../constants/index'

const scope = baseURL

export const pwa: ModuleOptions = {
  registerType: 'autoUpdate',
  scope,
  base: scope,
  manifest: {
    id: scope,
    scope,
    name: appName,
    short_name: appName,
    description: appDescription,
    theme_color: '#ffffff',
    icons: [
      {
        src: 'pwa-192x192.png',
        sizes: '192x192',
        type: 'image/png',
      },
      {
        src: 'pwa-512x512.png',
        sizes: '512x512',
        type: 'image/png',
      },
      {
        src: 'maskable-icon.png',
        sizes: '512x512',
        type: 'image/png',
        purpose: 'any maskable',
      },
    ],
  },
  workbox: {
    clientsClaim: true,
    skipWaiting: true,
    // globPatterns: ['**/*.{js,css,html,txt,png,ico,svg}'],
    // navigateFallbackDenylist: [/^\/api\//],
    navigateFallback: undefined, // '/'
    // cleanupOutdatedCaches: true,
    // runtimeCaching: [
    //   {
    //     urlPattern: /^https:\/\/fonts.googleapis.com\/.*/i,
    //     handler: 'CacheFirst',
    //     options: {
    //       cacheName: 'google-fonts-cache',
    //       expiration: {
    //         maxEntries: 10,
    //         maxAgeSeconds: 60 * 60 * 24 * 365, // <== 365 days
    //       },
    //       cacheableResponse: {
    //         statuses: [0, 200],
    //       },
    //     },
    //   },
    // ],
  },
  registerWebManifestInRouteRules: true,
  writePlugin: true,
  devOptions: {
    enabled: process.env.VITE_PLUGIN_PWA === 'true',
    navigateFallback: scope,
  },
}
